草庐IT

xml - XPath 3.x - 排序功能

全部标签

ruby-on-rails - 如何在 ruby​​ 中使用 sort_by 按字母顺序对数组进行排序?

我有一组成员资格。每个成员中都有一个组。我需要按组名对这个成员资格数组进行排序。我尝试了很多不同的方法,最新的方法是这样的:@memberships.sort_by!{|m|m.group.name}但是,这不按名称排序。它似乎是对数组进行随机排序。成员属于:组组has_many:memberships@memberships等于:[{id:2141,user_id:491,group_id:271,member_type:"member",group:{id:271,name:"Derek's",privacy:"open",bio_image_url:"/bio_images/me

ruby - 如果不修改,在迭代之间保留哈希排序?

如果我遍历一次哈希,然后在不修改内容的情况下再次这样做,是否保证键以相同的顺序出现?快速测试表明:>h={'a'=>1,'b'=>2,'c'=>3}>100_000.times.map{h.to_s==h.to_s}.all?=>true另一个问题,如果允许上述情况,我可以遍历它只更改值,而不添加任何新键,并保持键的顺序不变吗?类似于这个python问题:Dodictspreserveiterationorderiftheyarenotmodified?与建议的重复项不同,我对元素是否具有完全指定的顺序不感兴趣,我只关心两次连续迭代未修改提供相同序列的限制。

ruby - 如何按长度对 Ruby 字符串数组进行排序?

我该如何排序:arr=["aaa","aa","aaaa","a","aaaaa"];进入这个?arr=["a","aa","aaa","aaaa","aaaaa"]; 最佳答案 arr=arr.sort_by{|x|x.length}或者在1.8.7+中:arr=arr.sort_by(&:length) 关于ruby-如何按长度对Ruby字符串数组进行排序?,我们在StackOverflow上找到一个类似的问题: https://stackoverflow

ruby-on-rails - 如何在两个字段中对 ruby​​/rails 进行排序?

比如我想按game_date排序,如果date相同就按team排序?执行此操作的最佳方法是什么?@teams=@user.teams@games=@teams.reduce([]){|aggregate,team|aggregate+team.games}.sort_by(&:game_date) 最佳答案 最好的方法是让您的数据库执行此操作,但如果您想使用Ruby:@games=@data.sort_by{|x|[x.game_date,x.team]}Array的排序行为是按第一个成员排序,然后是第二个,然后是第三个,依此类推。

ruby - 按可能为 nil 的属性对对象的 ruby​​ 数组进行排序

我有一个对象数组,我需要按可以是整数或nil的位置属性对其进行排序,并且我需要具有nil位置的对象位于数组的末尾。现在,我可以强制位置返回一些值而不是nil,这样array.sort就不会失败,但是如果我使用0作为默认值,那么它会将这些对象放在排序的前面。做这种事情的最好方法是什么?我是否应该将nil值设置为一些“几乎”总是保证在末尾的高得离谱的数字?还是有其他方法可以使array.sort方法将nil属性对象放在数组的末尾?代码如下所示:classParentdefsorted_childrenchildren.sort{|a,b|a.positionb.position}enden

ruby - ruby 中 "&: "运算符的功能是什么?

这个问题在这里已经有了答案:关闭10年前。PossibleDuplicate:Whatdoesmap(&:name)meaninRuby?我遇到了一个代码片段,其中包含以下内容a.each_slice(2).map(&:reverse)我不知道&:运算符的功能。这是如何运作的?

ruby-on-rails - 如何按降序对哈希值进行排序并在 ruby​​ 中输出哈希值?

output.sort_by{|k,v|v}.reverse和keyh={"a"=>1,"c"=>3,"b"=>2,"d"=>4}=>{"a"=>1,"c"=>3,"b"=>2,"d"=>4}Hash[h.sort]现在我有这两个。但我正在尝试按值降序对哈希进行排序,以便它返回=>{"d"=>4,"c"=>3,"b"=>2,"a"=>1}提前致谢。编辑:让我发布整个代码。defcount_words(str)output=Hash.new(0)sentence=str.gsub(/,/,"").gsub(/'/,"").gsub(/-/,"").downcasewords=senten

ruby - 根据另一个数组的元素对一个数组进行排序

我有一个id数组a1=[1,2,3,4,5]我还有另一个ID随机排列的对象数组a2=[(obj_with_id_5),(obj_with_id_2),(obj_with_id_1),(obj_with_id_3),(obj_with_id_4)]现在我需要根据a1中id的顺序对a2进行排序。所以a2现在应该变成:[(obj_with_id_1),(id_2),(id_3),(id_4),(id_5)]a1可能是[3,2,5,4,1]或任何顺序,但a2应对应于a1中id的顺序。我喜欢这样:a1.each_with_indexdo|id,idx|found_idx=a1.find_inde

ruby - 使用 Ruby 解析 XML

我是使用XML的新手,但刚好有需要。我得到了一种常用的(对我而言)XML格式。标签内有冒号。1234TheName这是一个大文件,其中包含的内容远不止于此,但我希望有人会熟悉这种格式。有谁知道处理此类XML文档的方法吗?我宁愿不只是编写一种解析文本的蛮力方法,但我似乎无法使用REXML或Hpricot取得任何进展,我怀疑这是由于这些不寻常的标签。我的ruby代码:require'hpricot'xml=File.open("myfile.xml")doc=Hpricot::XML(xml)(doc/:things).eachdo|thg|['Id','Name'].eachdo|el|

ruby - Ruby 中的排序稳定吗?

Ruby中的sort稳定吗?也就是说,对于sort并列的元素,它们之间的相对顺序是否保留了原始顺序?例如,给定:a=[{id::a,int:3},{id::b,int:1},{id::c,int:2},{id::d,int:0},{id::e,int:1},{id::f,int:0},{id::g,int:1},{id::h,int:2},]是否保证我们总能得到a.sort_by{|h|h[:int]}以下[{id::d,int:0},{id::f,int:0},{id::b,int:1},{id::e,int:1},{id::g,int:1},{id::c,int:2},{id::h